草庐IT

Rust 并发编程

全部标签

go - golang 使并发更容易的关键原因

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭7年前。Improvethisquestion我的理解大概在下面吗?go可以大部分在编译时检测死锁。go可以使用chan来最小化racecondition是因为只有单个发送者或接收者goroutine一次可以访问任何特定的chan。

golang 发出并发请求并合并响应

我编写了独立调用多个http请求并合并结果的go代码。有时组合方法会缺少值。funcprofile(req*http.Request)(UserMe,error,UserRating,error){wgcall:=&sync.WaitGroup{}uChan:=make(chanResUser)rChan:=make(chanResRating)//variableinitsvarmeRespUserMevarratingRespUserRatinggofunc(){res:=但是me和rating调用会按预期返回来自api请求的值。funcme(req*http.Request,wg

go - 使用互斥锁但仍然有并发映射写入

我有一张map,想手动进一步分片,简化代码是const(dictShardNum=16dictShardSize=1运行时我在该行遇到fatalerror:concurrentmapwrites,但我确实锁定了互斥量,不确定我的代码有什么问题 最佳答案 Packagesyncimport"sync"typeMutexAMutexisamutualexclusionlock.ThezerovalueforaMutexisanunlockedmutex.AMutexmustnotbecopiedafterfirstuse.您的代码无法编

go - golang 中缓冲 channel 上的并发读取冲突?

我有一个被多个(在本例中为4个)go例程读取的缓冲channel。queue:=make(chanstring,10000)//alargebufferedchannel每个go例程检查channel中可用元素的数量并处理它们。fori:=0;i多个go例程会在读取时发生冲突吗?换句话说,不同的go例程是否可以在channel中获取相同的元素,或者当一个go例程正在读取缓冲区时,其他go例程已经读取并处理了一些元素?如何在一个goroutine正在读取时阻止其他goroutine读取? 最佳答案 简单的回答:没有。放置在Gochan

go - 无法理解电子书中的并发示例

我很难从电子书中理解并发性。我希望有人可以和我一起逐步进行故障排除,这样我就可以清楚地了解发生了什么。这里是主要方法:funcmain(){c:=make(chanint)goprinter(c)wg.Add(1)//Send10integersonthechannel.fori:=1;i这是打印方法:funcprinter(chchanint){fori:=rangech{fmt.Printf("Received%d",i)}wg.Done()}这是我的问题:为什么我们只将wg.Add(1)作为一组来等待,而不是在main方法中执行wg.Add(1)循环我真的不了解channel,期

go - 如何并发优化大型递归任务

我有一个chron任务要在Golang中以最佳方式执行。我需要在sellers中以JSON格式存储来自Web服务的大数据将这些sellers保存到数据库后,我需要浏览另一个带有sellersID参数的大型JSON网络服务,以保存到另一个名为customers的表.每个customer都有一个初始状态,如果这个状态已经从web服务的数据改变(n°2)我需要将差异存储在另一个表中changes以获取更改历史记录。最后,如果变化等于我们的条件,我将执行另一项任务。我目前的操作varwgsync.WaitGroupaction.FetchSellers()//fetchlargeJSONand

go - 如何以编程方式调用 Gurilla Mux 处理程序?

我正在尝试在另一个处理程序函数中以编程方式调用GurillaMux处理程序。简单地调用该处理函数是行不通的,因为它使用了mux.Vars()。我手头有一个URL。因此,我正在寻找一种方法来调用该处理程序函数,就好像用户访问了该URL一样,我希望返回响应以进一步处理它。有谁知道如何做到这一点? 最佳答案 为什么调用函数不起作用?mux.Vars()的数据存储在将请求映射到相关数据的全局上下文中。只要将相同的请求指针传递给处理程序,它就可以访问mux.Vars()。 关于go-如何以编程方式

go - 并发如何与匿名函数一起工作?走

我正在尝试遍历列表(例如sql行)并为每一行触发例程。问题是传递给函数的值不会在运行时进行评估,因此根据函数执行所需的时间,它可能会使用下一行中的任何值而不是当前行。我知道我可以在普通函数中提取函数并传递参数,但我仍然想共享一些全局变量(以避免许多函数参数)因此需要使用匿名函数。仍然让我感到困惑的是,匿名函数在执行时从环境中获取变量,因为据我所知,它应该像&在unix程序中一样在单独的例程中执行,通信仅通过channel完成。问题是如何让匿名函数接收vc的副本并在运行时使用它?packagemainimport"fmt"import"time"typemystructstruct{ii

go - 坚持 Go 并发

我似乎不知道下一步该做什么。我的目标是使用图像包中的SubImage函数从原始图像创建一个包含所有子图像的数组。我能够在imageSplit()函数中分割图像并通过channel传递给imageReceiver()函数。我实际上在函数imageReceiver()中接收数据,但我不知道如何在从imageSplit()函数接收到所有图像后附加到数组并使用它。//PartitionsImagefuncPartition(srcimage.Image)[]image.Image{newImg:=image.NewNRGBA64(src.Bounds())r:=newImg.Rectdx,dy

映射并发访问

当您在具有并发访问的程序中使用映射时,是否需要在函数中使用互斥锁来读取值? 最佳答案 多个读者,没有作家是可以的:https://groups.google.com/d/msg/golang-nuts/HpLWnGTp-n8/hyUYmnWJqiQJ一个作者,没有读者也行。(否则map就不会太好了。)否则,如果至少有一位作者和至少一位作者或读者,则所有读者和作者必须使用同步来访问map。互斥体可以很好地解决这个问题。 关于映射并发访问,我们在StackOverflow上找到一个类似的问题